Metadata management 
system В АВИТО 


Крючков Фрол 


е Ней! сас-- 
(HL) ж” 


Фрол Крючков 


В Авито с 2015 года 


--Занимался раскепа- 
разработкой 


— Team lead@core-services 


— Team lead@trust&safety 


Об Авито 


Всего сотрудников: 

Команда разработки: 
Среднии возраст сотрудников: 
Количество серверов: 

RPS к бэкенду: 

MAU: 

Релизов изменении: 

Команд разработки: 


Модерациа: 


Продано товаров в 2019 
году: 


2200 + чел. 

650 + чел. 

28 лет 

1000+ 

96 000 

50 миллионов чел. 
200-250 в день 

58 


4 миллиона версии обьявлений 
вдень 


1,32 триллиона рублей, или, 
1,45% ВВП России 


ТА HighLoad 
(HL) аА 2021 Шы 


План 


Почему важно Архитектура 
зтим metadata Плюсы/ 
заниматься management system минусы 


у 


Что такое Ограничения Deep dive 
metadata старои сервиса layout 
архитектуры 


4 Qu: 


План 


u 


Что такое 
metadata 


5 (нї) Hen оа 


metadata — это данные о данных 


ТА HighLoad 
(HL) on 2021 "° 


Descriptive metadata 


TITLE 


CATEGORY 


PRICE 


DESCRIPTION 


HighLoad++ 
Весна 2021 


SUBMITTING А NEW ADVERTISEMENT 


Structural metadata Е СЕ 


SEARCHING 


` = 


8 HL) менед» 


Какие решениа 
уже существуют? 


' X HighLoad+ 
Í (HL) дч 


970 = FF Project Core Services - Fields х + о 


< а а jr.avito.ru/plugins/servl хо» о Update 


Dashboards v Projects v Is М 


Е Project settings 


Ш) 
е Summary Fields 
Details Fields hold the information abc 
ields behave is defined by a fi 
fields behave is defined by a fi 
& Issue types The field configuration scheme 
Bug available, contact your Jira adr 
[ЕЈ I 
Epic 5 
Ө Scheme used by this рес 
о Improvement 
Какие решениа Ф "сон ~ сояу Ez 
Research 


These 8 issue types... 


уже существуют? й исе 


Improvement 


Sub-Task © Refactoring 
Support ГА Research 
Retro Al 
Workflows © Sprint Goal 
Screens E Support 
Ti 

Fields E sub-Task 
Priorities 
Versions 


Components 


Component Watchers 


Users and roles 


» қ 
Permissions 


10 ні) менге 


озо (у Manage Categories ‹ Site Tite х + ° 


е С в wordpress.com/settings/taxonomies/categoryfrol дрге55.сот ъ ж Q # Фѓоге: 


@ музне БИ Reader Ф Ф 
еШ Site Title 


Free domain with ən 
annual plan 


А муноте 


€ Back Categories 


О, Search Add New Category 


sil Stats ©, uncategorized : 


ЈЕ Upgrades 


Какие решениа ки 


уже существуют? Ё 


Media 


Pages 


Comments 


Feedback 
Jetpack 


Appearance 


Plugins © 


Users 


++ 
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Весна 2021 


План 


Почему важно 
зтим 
заниматься 


_____„ -- 


12 (ні) ного» 


submitting forms search filters 


РолБ metadata дла search indexing 
сайта обьявлений 


items раде listing fees 


fraud detection 


13 (ні) HighLoad++ 


Ul изменениа форм 
Изменениа валидаторов 
Антифрод модели 
Рекомендательные системы 
Ценовье политики 
Индексациа 

SEO 


Процесс изменениа 
метаданньх 


ш (ни) Нет оган“ 


План 


— e У 


Ограничениа 
старои 
архитектурь 


15 (ні) ного» 


Проблема 


Ul изменения форм 
Изменения валидаторов 
Антифрод модели 
Рекомендательные системы 
Ценовые политики 
Индексациа 

SEO 
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От однои недели до 
нескольких месяцев 


"А HighLoad 
(HL) on 2021 i 


е Уменьшить время внесениа 
изменении 
Functional е Разное представление на разных 
requirements платформах 
Поддержка а/Б тестированиа 
е Поддержка версионированиа 
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ТА HighLoad 
(HL) on 2021 i 


Старая архитектура 


| | | 524 | | 
ID i TITLE CATEGORY ID PARAMETER 1 | ... РАВАМЕТЕВ М | PRICE DESCRIPTION 


18 адын 


узегтезлезцовцузегоуна гапецулеаиоп. схоериоп > р 


по Add.php (с) MagicNumbersAdd.php © FirstLine.php ge ParamValue.php 3. Obj_Location156.php і 


<?рһр 
// generated by Core\Utils\0bj\Dict::storeDict() (see Obj_Location::getDict()) 
return array ( 
626740 => 
array ( 
"рагеп 14" => 626470, 
‘countryId' => 621540, 
"пате" => "Биробиджан", 
'патебепі+іме' => "Биробиджана", 
"патеРгеро5ј опа" => "Биробиджане", 
‘slug’ => 'birobidzhan', 
‘type’ 3, 
‘isCapital' => true, 


Описание иерархии ШЕ 


624360 => 
18 аггау ( 
) ‘parentId' => 624300, 

‘countryId' => 621540, 
"пате" => "Владимир", 
‘nameGenitive' => "Владимира", 
*namePrepositional’ => "Владимире", 
"вид" => ‘vladimir’, 
‘type’ => 3, 
‘isCapital' => true, 

2 ‘regionCode' => "822", 
"14" => 624360, 


array ( 
‘parentId' => 624770, 
‘countryId' => 621540, 
"пате" => "Волгоград", 
‘nameGenitive’ => "Волгограда", 
‘namePrepositional' => "Волгограде", 
"5109' => ‘volgograd', 
"Хуре" 3, 


%2565-2451% — жел 


19 ні) менге 


Performance 
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var 


cache 


DIContainer 
dicts 
.gitkeep Файлы данных словарей 
ге Obj_AvitoVersion.php 
ге Obj_Avtokod_Brand.php 
ие Obj_Avtokod_Brand_avtokodBrand.idx.php 
ва Обі Вохбеггу оса оп.рћр 
ва Обі Сагедогу ІМЕМ-948.рһр 
ге Obj_Category_slug.idx_INFM-948.php 
== ОБј СУ РаскадеТуре.рһр 
по Obj_District.php 
ве Obj_District_locationld.idx.php 
ге Obj_Event.php 
ге Obj_Fee20_ChildExceptLocations.php 
по Обі Еее20 | осаНоп.рпр 
по Obj_Fee20_Package_RootMicroCategory.php 
ге Obj_Infomodel_Version.php 
ге Обі Шет АризеТуре.рпр 
по Obj_ltem_CloseReasons.php 
па Obj_ltem_CloseReasons_categoryld.idx.php 
оо Obj_ltemStatus.php 
зо Obj_LegalEntity.php 
ве Obj_Location.php 
ге Obj_Location.shards.php 
ге Obj_Location155.php 
по Obj_Location156.php 


Г\ HighLoad 
(ис ee 


Фундаментальные 
Недостатки старой е Наша реализация 


архитектуры зависимостей 
ө Технические ограничения 


— (на) на сва 


Изменение метаданных требует: 
Фундаментальный 


ө Изменения схемы базы данных 
недостаток 


ө Пересборку проекта 


22 (Ft) менед 


Наша реализациа зависимостеи 


Значения вакансий и резюме имеют разные идентификаторы: 


° Ж 
% Avito Новое обьявление 


Категория 


Транспорт 


Недвижимость 


Услуги 

Личнье вещи 

Для дома и дачи 
Бытовая электроника 
Хобби и отдых 
Животные 


Готовый бизнес и оборудование 
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Р 
IT, интернет, телеком 


Автомобильный бизнес 


Административная работа 


Банки, инвестиции 

Без опыта, студенты 
Бухгалтерия, финансы 
Высший менеджмент 
Госслужба, НКО 
Домашний персонал 
ЖКХ, эксплуатация 
Искусство, развлечения 
Консультирование 
Маркетинг, реклама, PR 
Медицина, фармацевтика 


Образование, наука 


• Е 
% Avito Новое обьявление 


Категория 
Транспорт Резюме 
Недвижимость Вакансии 
— 
Услуги 


Личнье веци 

Дла дома и дачи 
Бытовая электроника 
Хобби и отдых 
Животные 


Готовый бизнес и оборудование 


ІТ, интернет, телеком 
Автомобильный бизнес 
Административная работа 
Банки, инвестиции 

Без опыта, студенты 
Бухгалтерия, финансы 
Высший менеджмент 
Госслужба, НКО 
Домашний персонал 
ЖКХ, эксплуатация 
Искусство, развлечения 
Консультирование 
Маркетинг, реклама, PR 


Медицина, фармацевтика 


Образование, наука 


ІМ HighLoad 
ај дин 


Технические ограничениа 


бк значений — это "100 файлов словарей 
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сасће 


DIContainer 
dicts 
.gitkeep Файлы данных словарей 
ге Obj_AvitoVersion.php 
ге Obj_Avtokod_Brand.php 
ге Obj_Avtokod_Brand_avtokodBrand.idx.php 
ге Obj_BoxberryLocation.php 
ге Obj_Category_INFM-948.php 
ге Obj_Category_slug.idx_INFM-948.php 
ге Obj_CV_PackageType.php 
ге Obj_District.php 
гг Obj_District_locationid.idx.php 
ге Obj_Event.php 
ге Obj_Fee20_ChildExceptLocations.php 
ге Obj_Fee20_Location.php 
ге Obj_Fee20_Package_RootMicroCategory.php 
пе Obj_Infomodel_Version.php 
ге Obj_Item_AbuseType.php 
ге Obj_Item_CloseReasons.php 
ге Obj_Item_CloseReasons_categoryld.idx.php 
ге Obj_ItemStatus.php 
ге Obj_LegalEntity.php 
по Obj_Location.php 
ге Obj_Location.shards.php 
ге Obj_Location155.php 
ге Obj_Location156.php 


ЛОКК значений — это: 


«Out of Memory Killer» 


ІМ HighLoad 
HO il 


LAYOUT ADVERTISEMENTS ATTRIBUTE 


LAYOUT_ID | NAME ADV_ID i ATTR_ID - VALUE 


ADVERTISEMENTS 


| " 


Entity Attribute Value 
модель 


ADV_ID | USER_ID 


ATTR_ID I CATEGORY_ID у LABEL 


ATTRIBUTES LAYOUTS 


ID - ATTRIBUTE_ID ; LAYOUT_ID 
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Functional 
requirements 


e Управление метаданными 
е Логическая консистентность 


ТА HighLoad 
(HL) На дені: "° 


План 


Архитектура 
metadata 
management system 


______________- 


27 (HL) HighLoad++ 


Компонентнаа 
схема 


CONSUMER SERVICES 
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metadata 


management 


system 


У 


VERSIONS ОР МЕТАРАТА 
STORAGE (NGINX) 


ж 


rule engine 
service 


layout 
service 


ж 5 


search payment 
service service 


SEO 
service 


listing fees 
service 


ads filters 
service 


ads crea- 
tion servi- 


eee чи Categories / master /Infomod: X + 


< С А NotSecure | infm.avito.ru/#/branches/master/categories/ у w Се Oak о 
я Classification trees Na 1 main main Ө ~ + 9 


Infomodel / Categories 


The branch was released by @mslanin a день назад (version INFM-3169 ). То make changes, create a new one. 


Tests passed successfully Release Description Release logs 


Categories 
Metadata 

management 
AVITO urls В 13 attributes properties 
syste rm Transport urls В 0 attributes properties 
Cars urls P 75 attributes properties 
Motorcycles and mototechnics urls В 4 attribute properties 
Trucks and special equipment uris? fourteesttributes properties 
Water transport игі” 3 attribute properties 
Parts and accessories urls В 45 attributes properties 
The property uris?  elevenattributes properties 
Apartments uris? 106 attributes properties 
Rooms ші” 68 attributes properties 
Houses. summer cottages, cottages urls В 73 attribute properties 


infm.avito.ru/#/branches/master/trees/ 


~ Јао якою 


29 HL) HighLoad++ 


> 


Frontend сло 
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Раса model 


Примеры layouts 


Формы 


32 


Canonical игі 


есе 22 Купить BMW 1 серия в Mocke X -- 


< с https://www.avito.ru/moskva/avtomobili/bmw/1-seriyal 


900 “нос 


< С (а avion 


Технические характеристики 


Марка Еога 


Модель - 


История эксплуатации и состояние 


Пробег км 
Состояние Небитьй | Битьй 
Владельцев по ПТС 1 2 3 4 
Данные о ТО Есть сервисная книжка 
Обслуживался у дилера 


mansana л 


Дополнительные опции 
Усилитель руля Помощь при вождений 
- Автоматический парковщик 
Датчик дождя 
Датчик света 


Управление климатом 


Audi 95, 2021 
4 310 000 P 
‘Brannan 


2.0 AMT (249 л.с.), внедорожник, 
полный, бензин 


Сниппеты 


Volkswagen Polo, 2021 9 
от 1 386 189 2 

1 436 189 Р без скидки 

„В наличии 


1.4 АМТ (125 л.с.), хетчбзк, передний, 


"А HighLoad 
HL о id 


Rules 
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у, 


field: 503, 
- states: | 


1, 


type: "visible", 
- constraints: | 


- | 


- í 
field: 201, 
- condition: ( 
- values: | 
1060 
1, 
strict: false, 
у, 
>, 
-{ 
field: 504, 
- condition: { 
empty: true 
у, 
у 
1, 
= | 
erf 
field: 201, 
- condition: { 
- values: | 
1060 
1, 
strict: false, 
у, 
>, 
-4 


field: 504, 
- condition: 4 
- values: | 
5256 
1, 
strict: false, 
у, 
}, 
1, 


ІМ HighLoad 
i. 


Relations 


34 


options: ( 


- fields: | id: 110001, 
={ - values: [ 
id: 110000, - 4 
splitted: true, - value: ( 
- values: | уа1че: 329836, 
- 4 label: "CL", 
= value: | }, 
value: 329192, - fields: | 
label: "АС", -4 
у, 14: 110005, 
fields: “relations/110000-329192.json.gz", - valu І 
» =f 
-{ - value: 
- value: { value: 
value: 329193, 
label: “Acura”, } 
у, у, 
fields: “relations/110000-329193.json.gz", =f 
+; - value: ( 
= value: 
- value: ( label: 
value: 426153, у 
label: "Adler", » 
>, 1, 
fields: "relations/110000-426153.4json.gz", › 
У; 1, 
>f }, 
- value: { зм 
value: 329194, тн С. 
label: "Alfa Romeo", value: 2 ња 
$. label: "сок", 
й I à “ у, 
fields: lat /110000-329194. 62", 
5 elds: "relations json.gz сан 
' 
- < 
-í 14: 110005, 
- value: ( 1 А 
value: 329195, Ба ај t 
label: "Alpina", жайған 1 
А 148: “relati /110000-329195.3 £ вена 
) ields: relations - .јѕоп.92°, label: 
d ) 
ЕЕ! ) 
- value: 4 1, 
value: 473599, ) 
label: "Alpine", 1, 
» | р № 
fields: "ге1асіопв/110000-473599.3воп.42", - { 
у, - value: | 
- value: 329990, 
- value: | label: "EL", 
value: 427103, у, 
label: "АМС", - fields: | 
}, а 


fields: “relations/110000-427103.json.gz", 


id: 110005, 


332068, 
"1 (1996-1999)", 


332069, 
"11 (2000-2003)", 


332070, 
"I (2005-2011)", 


НЕН! сасње 


- fields: [oe 


-к 
14: 201, 
Жүре: "enumerable", 
епитегабі: true, 


dataType: "integer", 

slug: "offer_type", 

label: "Тип объявления", 
- validation: | 


rule: "required", 
де: "Выберите значение из списка", 
severity: "error", i 


) 
1, 
multiple: false, 
range: false, 
fillable: true, 
searchable: true, 
immutable: true, 
- tags: | 
"semantic 41" 


1, 
defaultValue: null, 
- measureUnits: ( 
one: null, 


Forms ЕНІН 
| five: null, 
uid: 10774, 


name: "params[201]", 
placeholder: null, 


help: null, 
- widget: ( 
type: “radioGroup", 
- config: ( 
limit: 2, 


reduced: "true", 
withUrls: true, 
hideTitle: "true", 
}, 
у, 
sorting: 2, 
visible: true, 
stepId: 363, 
catalog: null, 
prevEntity: null, 
parentEntity: ( 
id: 363, 
type: "step", 


у, 


35 НО) HighLoad++ 


Весна 2021 


Layout — гранулярность конфигурированиа 
единых метаданнь в разрезе платформы, 
категории, версии 


ТА HighLoad 
(HL) on 2021 "° 


Ветка master master д> + P © 


aa Й 


All | Му | АВ Feature 


AU-4081-parts-cars feature 


Версионирование 


208-4811 feature 
6Е0-2556 a ө 
e master master Ө 
АЏ-4909 feature © 
AU-4979-sort feature Ө 
АЏ-4594 feature 
AU-4894 feature 


і (нешс 


Релиз версии метаданньх 


є» T] | Ветка 208-4811 | feature М 


Создать релиз и заблокировать ветку 


38 


версия јор-4811 


layout : desktop_filters 


ІМ HighLoad 
(ин 


а/Б тестирование 


7% Ветка ЈОВ-4811 feature ~ x 


версия ab-test-4811 
| | Создать релиз и заблокировать ветку layout : desktop_filters 


й (и) ese 


layout X 


category x [layout, rule-engine, 


url-builder] services 
Дистрибьюция 


релиза метаданных 


layout X 


request [buld | validate | calc] 


layout {version}.{layout} 
{category} for [data] 


A = > г. 


40 (а) оон 


Routing 


41 


ver-1234.desktop_filter.cat2 
ver-1236.desktop_filter.cat2 


ver-1237.desktop_filter.cat2 


HighLoad+- 
HL Весна 2021 


Демонстрация работы 


1. í 
2% "route": { 
3; "categoryId": 24, 
4. "layout": "desktop_catalog_filters", 
Ба "version": "master" 
6. у, 
Ta "form": [], 
8. } 
42 


service-layout 


ІЙ HighLoad++ 
(HL) Нені 


Демонстрация работы 


"result": { 
"Ебтш": | 
{ 
"data": 
"за": 201, 
"value": 1059, 
"options": | 


= ы сул Q) N > 


10. "за": 1059, 
ат. "label": "Купить" 


14. "за": 1060, 
15. "label": "Снять" 
16. }, 


18. "за": 1058, 

19. "label": "Покупатели" 

у 20. }, 

service-layout 21. | 
22. "id": 1061; 

23. "label": "Арендаторь" 

24. ) 

25. 1, 

26. "label": "Тип объявления" 

27. +, 

28. "needUpdate": true, 

29. "needDataSend": true 


32. "дака": ( 

33, "34": 578, 

34. "value": null, 

35. "label": "Обшая площадь" 
36. }, 

37% "needUpdate": false, 

38. "needDataSend": false 

39. }, 


ІЙ HighLoach+ 
43 HL А 


Демонстрация работы 


= ы суль мн 


= во 
= о. 


H 
N 


вены 
ою со м) фу Сл Ww 


NNN 
NRO 


~ 
о 


NN бо о Юю 
оо що слм 


из нъ Q) ш WWW ww Www 
=ососомјфал=>озмне 


т 
~ 


"result": 


{ 


“£orm": | 


{ 


+, 


"data": | 
"іа": 201, 
"value": 1059, 
"options": | 
( 
"за": 1059, 
"label": "Купить" 
}, 
{ 
"id": 1960, 
"label": "Снять" 


"за": 1058, 
"label": "Покупатели" 


"за": 1061, 
"label": "Арендаторы" 
) 

1, 
"label": "Тип обьявления" 
}, 
"needUpdate": true, 
"needDataSend": true 


"data": | 
"за": 578, 
"value": null, 
"label": "Общая площадь" 


}, 
"needUpdate": false, 
"needDataSend": false 


КупитБ 


Количество комнат 
Студия 
Своб. планировка 
1 комната 


2 комнаты 


Цена 


Вид обьекта 


Все Вторичка 


Общая площадь, м? 


Зтаж 


Не первый 


Зтажей в доме 


Тип дома 


Кирпичньй 


Снять 


3 комнаты 
4 комнаты 


5 комнат и более 


Новостройка 


Не последний 


Монолитный 


ІМ HighLoad 
ае 


Демонстрация работы 


Купить Снять 


Количество комнат 


Студия 3 комнаты 
Своб. планировка 4 комнаты 
1 комната 5 комнат и более 
2 комнаты Та ( 
2. "route": | 
Цена З. "са+едогуІа": 24, 
4. "layout": "desktop_catalog_filters", 
LI 5, "version": "master" 
6 . ) , 
Вид обљекта > Pe “form”: | 
Все Вторичка Новостроика 8. { 
8. "ій": 499, 
10, "value": 5255 
Срок сдачи 
ШЕШЕ із 
С 1:2; 
Общая площадь, м? 
Зтаж 
Не первый Не последний 
++, з, 
45 HL НЕН! сасње 


Весна 2021 


Демонстрация работы 


1. ( 
2; "route": ( 
33 "categoryId": 24, 
4. "layout": "desktop_catalog_filters", 
5. "version": "master" . 
6. |, —— service-layout 
Па "form": | 
8: { 
9. "іа": 499, 
10. "value": 5255 
11. ) 
12; 
46 HL) HighLoad= 


Весна2021 


Демонстрация работы 


47 


service-layout 


27 


30 


36 


"result"; | 
"form": 


( 


[ 


"дака": | 


"іа": 110684, 
"value": null, 


"label": "Срок сдачи" 


) 


"needDataSend": 


"data": | 
"за": 1383, 


"needUpdate": false, 


false 


"уаїше": null, 


"label": "Название новостроики" 


}, 


"needUpdate": false, 


"needDataSend": 


"data": { 
"id": 1634, 


false 


"value": null, 


"label": "... 


}, 


"needUpdate": false, 


"needDataSend": 


"data": ( 


false 


"іа": 100003, 
"value": null, 
"label": "Цена" 


) 


"needDataSend": 


"needUpdate": false, 


false 


НО HighLoad+ 


Демонстрациа 
работы 
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ЕЗ 


"result": | 
"form": 


{ 


| Купить 


"дака": 1 Количество комнат 
"id": 110684, 

"уаїше": null, 
"label": "Срок сдачи" 


Студия 


Своб. планировка 
) 


"пеедОрдаїе": false, 1 комната 
needDataSend": false қаты 
"data": | Цена 
"аа": 1383, 
"value": null, Цена от 
"label": "Название новостроики" 


) 


, Вид обьекта 
"needUpdate": false, 


ВЕ азан ES БА, В РА. а Вторичка 
Срок сдачи 
"дака": | 
"ча": 1634, Срок сдачи 
"уаїше": null, 
"label" : " ы-і " = 
а Дом сдан 
"needUpdate": false, сд 


"needDataSend": false 


"дака": | до 2 квартала 2021 


"іа"; 100003, 
"уаїше": пи11, 
"label": "Цена" 


до 3 квартала 2021 


) до 4 квартала 2021 


"пеед рдаће" : 
"needDataSend": false 


false, 022 


до 1 квартала 2022 


Снять 


З комнать! 
4 комнаты 


5 комнат и более 


Новостройка 


Получение следующего состояния 


Form state 


— 


Form state* | | is state valid 
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service-layout 


І HighLoach+ 


План 


= Џ(------- 


Deep dive 
сервиса layout 


50 (HL) HighLoac++ 


е Response time: 10гп5 на 999690 


Моп functional е Должен держать в памяти 
requirements <~10 000 layouts 


(layout может занимать до 500Mb) 


51 (Ft) менед 


Вьбор хранилиша 


БК ___-_ | 
— 
© 
TARANTOOL 


52 (Hu) нена" 


Request flow diagram 


nfomodel 


irl-builder] services 


(layout, rule-engine, 


= 
Ф 
Е 
5 
л 
с 
S 
о 


' 
' 
' 
' 
see if layout (version).(layout). ! 
(category) is already compiled апа іп | 
memory ' 
' 
—T c 
: 
| Мо required layout compiled | 
' 


layout {version}.{layout}.{category} 


request [build |validate] 
for [data] 
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B худшем случае количество памати 
Проблема хранения | „у, 1500 layouts - 700Gb! 


данных 
На один инстанс сервиса 


54 (Ft) менед 


~токвр 
Внутренняя структура forms.json 
хранилиша 
relation.json 


55 (и мен 


Пример дерева я А 
зависимостей а ДЕ и 


56 (ну) неш 


Переиспользование 
прототипов 


50Mb — все еще 


МНОГО 


Й HighLoad 
(HL) on 2021 "° 
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ПереисполБзование прототипов 


Compiled layouts 


relations 
Hash: aaa 


layout: ver2.desktop_add.9 


layout: ver1.desktop_add.9 
relations 
Hash: bbb 


layout: ver3.ios_add.9 


relations 
layout: ver3.android_add.9 


binary prototypes 


ІЙ HighLoad++ 


Политики вытеснения 


LRU - x; СЕЈ - x; АВС -v 


Routes, RPM 
1.5Mil == =— -- - - — — ня = - P 
~ 87 еар 8 — = п == - s= _— 
ТОМИ — —Y — — —— — — „„ —— 
ок =— w — === =N - 
0 — — — - - 
1445 14:50 14:55 15:00 15:05 15:10 15:15 15:20 15:25 15:30 15:35 


= AU-2794,mobile_view_seller == AU-2794.mobile_catalog_filters == GEO-1620-ios.monolith_filters == GEO-1620-ios.desktop_view == AU-2794.desktop_profile_filters == AU-2794.monolith_filters == AU-2794.monolith_add == GEO-1620-ios.dictionary_view 


= GEO-1620-ios.desktop_profile_filters == AU-2794.dictionary_view == GEO-1620-ios.mobile_catalog_filters == GNRL-100-phones-2_17.mobile_catalog_filters == GNRL-100-phones-2_17.inline_catalog_filters «е GNRL-100-phones-2_1.marketplace == GEO-1620-ios.desktop 


= AU-2794.breadcrumbs_serp_desktop AU-2794.desktop_view GEO-1620-fos.monolith_add == GEO-1620-ios.breadcrumbs_serp_mobile GEO-1620-ios.desktop_catalog_filters AU-2794.desktop == AU-2794.desktop_catalog_filters АЏ-2794 breadcrumbs_serp_mobile 


= GEO-1620-ios.breadcrumbs_serp_desktop == AU-2794.los_edit == GEO-1620-ios.breadcrumbs_item == |МЕМ-1044-ашоса pro_snippet == AU-2794.breadcrumbs_item == AU-2794.mav_add == GEO-1620-ios.moderation_item_ine_view == GEO-1620-os.mav_add «+ AU-2794.mav_edit 


59 н.) сан 


Политика вьтеснения layouts 
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ТА HighLoad 
(HL) ы 2021 "° 


Cache warmup 


read the list of layouts 


ме: их that аге in the Пу 


download actual 
layout specs 


write the current list of 
layouts in in-memory cache 


Instances of 
Service 
in production 


Instances of 
Service that 
spinning up 
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(ну) неш 


План 


Плюсы/ 
минусы 


О o 


62 (ні) НЕН. оган 


Плюсы 
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Быстрый релиз изменений 
Горизонтальное масштабирование 
системы 

Расширяемая архитектура 


4 НЕН! сас 
(ні) тя fi 


Минусы 
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е Значительное усложнение архитектуры 
е Бысокое потребление сети 
е Бысокое потребление сри 


5 НЕН! сас 
(HL) a 4 


Спасибо за внимание 


статья на medium 


| HighLoad. 
(HL) и а 


